<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  <meta http-equiv="X-UA-Compatible" content="ie=edge" />
  <title>Document</title>
  <!-- 导入页面的基本样式 -->
  <link rel="stylesheet" href="./css/search.css" />
  <!-- 导入 jQuery -->
  <script src="./lib/jquery.js"></script>
  <script src="./lib/template-web.js"></script>
</head>

<body>
  <div class="container">
    <!-- Logo -->
    <img src="./images/taobao_logo.png" alt="" class="logo" />

    <div class="box">
      <!-- tab 栏 -->
      <div class="tabs">
        <div class="tab-active">宝贝</div>
        <div>店铺</div>
      </div>
      <!-- 搜索区域（搜索框和搜索按钮） -->
      <div class="search-box">
        <input type="text" class="ipt" placeholder="请输入要搜索的内容" id="ipt" /><button class="btnSearch">
          搜索
        </button>
      </div>
      <!-- 搜索建议列表 -->
      <div id="suggest-list"></div>
    </div>
  </div>
</body>
<script type="text/html" id="tpl-suggestList">
  {{each result}}
  <div class="suggest-item">{{$value[0]}}</div>
  {{/each}}
</script>
<script>
  $(function () {
    let timer = null
    let cacheObj = {}

    function debounceSearch(kw) {
      timer = setTimeout(function () {
        getSuggestList(kw)
      }, 300)
    }

    $('#ipt').on('keyup', function () {
      clearTimeout(timer)
      let keywords = $(this).val().trim()

      if (keywords.length <= 0) {
        return $('#suggest-list')
          .empty()
          .hide()
      }

      if (cacheObj[keywords]) {
        return renderSuggestList(cacheObj[keywords])
      }
      debounceSearch(keywords)
    })

    function getSuggestList(kw) {
      $.ajax({
        url: 'https://suggest.taobao.com/sug?q=' + kw,
        dataType: 'jsonp',
        success: res => {
          console.log(res);
          renderSuggestList(res)
        }
      })
    }

    function renderSuggestList(res) {
      if (res.result.length <= 0) {
        return $('#suggest-list').empty().hide()
      }
      let htmlStr = template('tpl-suggestList', res)
      $('#suggest-list').html(htmlStr).show()

      var k = $('#ipt')
        .val()
        .trim()
      cacheObj[k] = res
    }
  })
</script>

</html>